home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Precision Software Appli…tions Silver Collection 4
/
Precision Software Applications Silver Collection Volume 4 (1993).iso
/
database
/
ifp1s157.arj
/
PAGE_02.PAS
< prev
next >
Wrap
Pascal/Delphi Source File
|
1993-06-26
|
4KB
|
135 lines
unit page_02;
interface
uses crt, ifpglobl, ifpcomon, ifpextrn;
procedure page02;
implementation
procedure page02;
var
cpu_info: cpu_info_t;
save_cpu_type: byte;
procedure showNDP(a: string; b: word);
begin
writeln(a);
caption2(' Infinity');
case b and $1000 of
$0000 : writeln('projective');
$1000 : writeln('affine')
end;
caption2(' Rounding');
case b and $0C00 of
$0000 : writeln('to nearest or even');
$0400 : writeln('down');
$0800 : writeln('up');
$0C00 : writeln('chop')
end;
caption2(' Precision');
case b and $0300 of
$0000 : writeln('24 bits');
$0100 : writeln('(reserved)');
$0200 : writeln('53 bits');
$0300 : writeln('64 bits')
end
end; {showNDP}
begin (* procedure page_02 *)
caption2('CPU');
cpu_info.test_type:='C';
CPUID(cpu_info);
with cpu_info do
begin
case cpu_type of
$00 : Writeln('8088');
$01 : Writeln('8086');
$02 : Writeln('V20');
$03 : Writeln('V30');
$04 : Writeln('80188');
$05 : Writeln('80186');
$06 : Writeln('80286');
$07 : begin
Write('i386');
if bugtst <> 0 then
Writeln(' - Contains POPAD bug (DON''T WORRY! Most 386''s have this. Hit F1 key)')
else
Writeln;
end;
$08 : begin
test_type:='N';
CPUID(cpu_info);
if ndp_type = 0 then
Writeln('i486SX')
else
Writeln('i486')
end
else
unknown('CPU', cpu_type, 2)
end;
save_cpu_type:=cpu_type;
case cpu_type of
$06..$08 : begin
caption3('Machine Status Word');
writeln(hex(MSW, 4));
caption3(' Bit 0 - Protected mode ');
yesorno(MSW and 1 = 1);
caption3(' Bit 1 - Monitor Coprocessor');
yesorno(MSW and 2 = 2);
caption3(' Bit 2 - Emulate Coprocessor');
yesorno(MSW and 4 = 4);
caption3('Global Descriptor Table ');
for i:=1 to 6 do
write(hex(GDT[i], 2), ' ');
writeln;
caption3('Interrupt Descriptor Table');
for i:=1 to 6 do
write(hex(IDT[i], 2), ' ');
writeln
end
end;
caption3('Interrupts acknowledged immediately after segment register change');
yesorno(intflag);
caption2('Coprocessor');
test_type:='N';
CPUID(cpu_info);
case ndp_type of
$00 : writeln('none');
$01 : showNDP('8087', ndp_cw);
$02 : showNDP('80287', ndp_cw);
$03 : if save_cpu_type = $08 then
showNDP('(built-in)', ndp_cw) {'486 has coprocessor built in}
else
if save_cpu_type = $06 then
showNDP('80287XL', ndp_cw)
else
showNDP('80387', ndp_cw);
else
unknown('coprocessor', ndp_type, 4)
end {case}
end;
caption2('BIOS coprocessor flag set');
yesorno(equip and $0002 = $0002);
caption2('BIOS Weitek coprocessor flag set');
with cpu_info do
begin
if (save_cpu_type = 7) or (save_cpu_type = 8) then
begin
test_type:='W';
CPUID(cpu_info);
yesorno(weitek and 1 = 1);
if weitek and 1 = 1 then
begin
caption3('Weitek addressable in real mode');
yesorno(weitek and $80 = $80)
end
end
else
Writeln('Not Applicable');
end;
end;
end.